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Description 

BACKGROUND OF THE INVENTION 

1 . Field of the Invention 

The invention relates generally to the field of digital 
data processing systems, and more specifically to a sys- 
tem for managing licensing for, and usage of, the various 
software programs which may be processed by the sys- 
tems to ensure that the software programs are used with- 
in the terms of the software licenses. 

2. Description of the Prior Art 

A digital data processing system includes three ba- 
sic elements, namely, a processor element, a memory 
element and an input/output element. Ttie memory ele- 
ment stores information in addressable storage loca- 
tions. This information includes data and instructions for 
processing the data. TTie processor element fetches in- 
formation from the memory element, interprets the infor- 
mation as either an instruction or data, processes the 
data in accordance with the instructions, and returns the 
processed data to the merrK>ry element for storage there- 
in. The input/output element, under control of the proc- 
essor element, also communicates with the memory el- 
ement to transfer information, including Instructions and 
data to be processed, to the memory, and to obtain proc- 
essed data from the memory. 

Typically, an input/output element includes a 
number of diverse types of units, including video display 
terminals, printers, interfaces to the public telecommuni- 
cations network, and secondary storage subsystems, in- 
cluding disk and tape storage devices. A video display 
terminal permits a user to run programs and input data 
and view processed data. A printer permits a user to ob- 
tain a processed data on paper. An interface to the public 
telecommunicatkins network permits transfer of informa- 
tk>n over the public telecommuncatkns network. 

The instructbns processed by the processor ele- 
ment are,typk:ally organized into software programs. Re- 
cently, generation and sales of software programs have 
become significant businesses both for companies 
which are primarily vendors of hardware, as well as for 
companies which vend software atone. Software is typ- 
ically sold under license, that is, vendors transfer copies 
of softv/are to users under a license which governs how 
the users may use the software. Typically, software costs 
are predicated on some belief as to the amount of usage 
which the software program may provide and the eco- 
nomic benefits, such as cost saving which may otherwise 
be incurred, which the software may provide to the users. 
Thus, license fees may be based on the power of the 
processor or the number of processors in the system, or 
the number of individual nodes in a networK since these 
factors provide measures of the number of users which 
may use the software at any given time. 



tn many cases, however, it may also be desirable, 
for example, to have licenses and license fees more 
closely relate to the actual numbers of users which can 
use the program at any given time or on the actual use 

5 to which a program may be put. Furthermore, it may be 
desirable to limit the use of the program to specified time 
pertods. A problem arises particularly in digital data 
processing systems which have multiple users and/or 
multiple processors, namely, managing use of licensed 

10 software to ensure that the use is within the terms of the 
Ircense, that is. to ensure that the software is only used 
on identified processors or by the numbers of users per- 
mitted by the license. 

Donald et ai, US Patent No. 4,471 ,1 63, discloses a 

15 protection system for controlling the operatton of a digital 
computer as to a partfcular program, wherein a program 
■kx:k' interfaces with the computer and authorizes oper- 
atton of the digital computer only if there is a certain re- 
lationship between a number contained in the program, 

20 a number contained in the tock, and a third number con- 
tained in a 'key' supplied to the tock. 

Lillie, US Patent No. 4,590,557. discloses a portable 
medium that contains a program and a preselected 
number that is decremented after each time the program 

2S is toaded. When the counter reaches zero, the program 
is erased. 

SUMMARY OF THE INVENTION 

30 The inventton provides a new and improved licens- 
ing management system and method for managing the 
use of licensed software in a digital data processing sys- 
tem, according to claims 1 and 1 3. 

In brief summary, the license management system 

3S includes a license management facility and a licensing 
policy module that jointly determine whether a licensed 
program may be operated. The license management fa- 
cility maintains a license unit value for each licensed pro- 
gram and a pointer to a table identifying a license usage 

^ altocatton unit value associated with usage of the li- 
censed program. In response to a request to use a li- 
censed program, the license management facility deter- 
mines whether the remaining license unit value exceeds 
the license usage allocation unit value associated with 

45 the use. If the license unit value does not exceed the li- 
cense usage allocation unit value, the license manage- 
ment facility permits usage of the licensed program and 
adjusts the license unit value by a function of the Itoense 
usage altocatton unit value to reflect the usage. On the 

so other hand, if the license unit value associated with use 
of the license program does exceed the license usage 
alkxation unit value, the licensing policy module deter- 
mines whether to allow the licensed program to be used 
in response to other licensing policy factors. 

55 

BRIEF DESCRIPTION OF THE DRAWINGS 

This invention is pointed out with particularity in the 
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appended claims. The above and further advantages of 
this invention may be better understood by referring to 
the f olbwing description taken in conjunction with the ac- 
companying drawings, in which: 

Fig. 1 is a general block diagram of a new system in 
accordarice with the inventkxi; 
Figs. 2 and 3 are diagrams of data structures useful 
in understanding the detailed operatkxi of the sys- 
tem depicted in Fig. 1; and 
Figs. 4A-1 through 4B-2 are flow diagrams which are 
useful in understanding the detailed operatk>ns of 
the system depicted in Fig. 1 . 

DETAILED DESCRIPTION OF AN ILLUSTRATIVE 
EMBODIMENT 

Fig. 1 depicts a general bkx:k diagram of a system 
in accordance with the invention for use in connection 
with a digital data processing system which assists in 
managing software use in accordance with software li- 
censes. With reference to Fig. 1 . the new system in- 
cludes a license management facility 1 0 which operates 
in conjunction with a license data base 11 and license 
unit tables 12. and under control of an operating system 
1 3 and licensing policy module 1 5 to control use of li- 
censed programs, such as Ircensed program 14, so that 
the use is in accordance with the terms of the software 
Ifcense which controls the use of the software program 
on a system 16 identified by a system marketing model 
(SMM) code in a digital data processing system. 

As is conventional, the digital data processing sys- 
tem including the Ircensing management system may in- 
clude one or more systems 1 6, each including one or 
more processors, memories and input/output units, in- 
terconnected in a number of ways. For example, the dig- 
ital data processing system may comprise one proces- 
sor, which may include a central processor unit which 
controls the system and one or more auxiliary proces- 
sors which assist the central processor unit. Alternative- 
ly, the digital data processing system may comprise mul- 
tiple processing systems, in which multiple central proc- 
essor units are tightly coupled, or clustered or networked 
systems in which multiple central processor units are 
loosely coupled, generally operating relatively autorto- 
mously, interacting by means of messages transmitted 
over a cluster or network connectbn. In a tightly coupled 
multiple processing system, for example, it may be de- 
sirable to control the number of users which may use a 
particular software program at one time. A similar restric- 
tion may be obtained in a cluster or network environment 
by controlling the number of particular nodes, that is. 
connections to the communications link in the cluster or 
network over which messages are transferred. In addi- 
tion, since the diverse processors which may be included 
in a digital data processing system may have diverse 
processing speeds and powers, represented by differing 
system marketing model (SMM) codes, it may be desir- 



able to include a factor for speeds and power in deter- 
mining the number of processors on whk:h a program 
may be used concurrently. 

As will be explained in greater detail below, the li- 
cense data base 1 1 contains a plurality of entries 20 (de- 
scribed below in connectk>n with Fig. 2) each containing 
information relating to the terms of the license for a par- 
ticular licensed program 1 4. In one embodiment such in- 
formatkxi may include a terminatbn date, if the license 
is for a partrcular time period or expires on a particular 
date, and a number of licensing units if the license is lim- 
ited by usage the license program. In that embodi- 
ment, the entry also includes identification of a Ik^ense 
unit table 40 (described bebw in connectkxi with Fig. 3) 
in the license unit tables 1 2 that identifies the number of 
allocatkn units for usage of the licensed program on the 
types of systems 1 6 whk:h may be used in the digital data 
processing system as represented by the system mar- 
keting model (SMM) codes. 

When a user wishes to use a licensed program 14, 
a GRANT LICENSE request message is generated 
whrch requests information as to the licensing status of 
the licensed program 1 4. The GRANT LICENSE request 
message is transmitted to the licensing policy nrodule 1 5, 
which notifies the operating system of the request The 
operating system 13, in turn, passes the request, along 
with the system marketing rrKxJel of the specific system 
16 being used by the user, to the license management 
facility 10 which determines whether use of the program 
is permitted under the license. 

In response to the receipt of the GRANT LICENSE 
request from the user and the system marketing nrKxlel 
(SMM) code of the system 1 6 being used by the user on 
which the Ibensed program will be processed, the li- 
cense management facility 10 obtains from the license 
data base the entry 20 associated with the licensed pro- 
gram 1 4 and determines whether the use of the licensed 
program 1 4 is within the tenms of the Ibense as indbated 
by the information in the license data base 11 and the 
Ticense unit tables 12. 

In particular, the license management facility 10 re- 
trieves the contents of the entry 20 associated with the 
licensed program. If the entry 20 indicates a terminatbn 
data, the Ibense nnanagement facility 1 0 compares the 
system data, whbh is maintained by the digital data 
processing system in a conventbnal manner, with the 
termination date identified in the entry. If the system date 
is after the terminatbn date identified in the entry 20, the 
Ibense has expired and the license management facility 
10 generates a usage disapproved message, whbh it 
transmits to the operating system 1 3. On the other hand, 
if the termination date indicated in the entry 20 is after 
the system date, the license has not expired and the li- 
cense management facility 10 proceeds to determine 
whether the usage of the Ibensed program 14 is permit- 
ted under other terms of the Ibense which may be em- 
bodied in the entry 20. 

In particular, the Ibense management facility 1 0 then 
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determines whether the usage of the licensed program 
is permitted under usage limitations. In that operation, 
the license management facility obtains the number of 
license units remaining, which indicates usage of the li- 
censed program 14 not including the usage requested s 
by the user, as well the identification of the table 40 in 
license unit tables 12 associated with the licensed pro- 
gram 14. The license management facility 10 then com- 
pares the number of license units which would be allo- 
cated for use of the licensed program 1 4, which it obtains 
from the table 40 identified by entry 20 in the license data 
base 1 1 , and the number of remaining units to determine 
whether sufficient license units remain to permit usage 
of the licensed program 14. 

tf the number of remaining license units indicated by 
entry 20 in the license data base 1 1 exceeds the number, 
from license unit tables 12, of license units which would 
be allocated for use of the licensed progam 1 4, the usage 
of the licensed program is permitted under the license. 
Accordingly, the license nnanagement facility transmits a 
usage approved response to the operating system 1 3. 
In addition, the license management facility 10 adjusts 
the number of remaining license units in entry 20 by a 
function of the license units allocated to use of the li- 
censed program to reflect the usage. 

On the other hand, if the number of remaining li- 
cense units indicated by entry 20 in the license data base 
is less than the number of license units which would be 
allocated for use of the licensed program 14, the usage 
of the licensed program 14 is net permitted by the li- 
cense. In that case, the license management facility 10 
transmits a usage disapproved response to the operat- 
ing system 13. In addition, the license management fa- 
cility 1 0 may also log the usage disapproved response; 
this information may be used by a system operator to 
determine whether usage of the licensed program 14 is 
such as to warrant obtaining an enlarged license. 

Upon receipt of either a usage approved response 
or a usage disapproved response to the GRANT LI- 
CENSE request, the operating system 1 3 passes the re- 
sponse to the licensing policy nrxxJule 15. If a usage ap- 
proved response is received, the licensing policy module 
normally allows usage of the licensed program 14. If a 
usage disapproved response is received, the licensing 
policy rrKxJule determines whether the usage of the li- 
censed program may be permitted for other reasons. For 
example, usage of the licensed program 14 may be per- 
mitted under a group License, whose terms are embodied 
in entries in group license tables 17. Under a group li- 
cense, usage may be permitted of any of a group of li- 
censed programs. The operations to determine to wheth- 
er usage is permitted may be performed in the same 
manner as described above in connection with license 
management facility 10. In addition, if the usage of the 
licensed program 14 is not permitted under a group li- 
cense, usage may nonetheless be permitted urder the 
licensor's licensing practices, which may be embodied 
in the licensing policy module 15. If the licensing policy 



module determines that usage of the program should be 
permitted, notwithstanding a usage disapproved re- 
sponse from the license management facility 10, be- 
cause the usage is permitted under a group license or 
the licensor's licensing practices, the licensing policy 
nrKxjule 15 permits usage of the licensed program. Olh- 
enAflse, the licensing policy module does not permit us- 
age of the licensed program in response to the GRANT 
LICENSE request. 

When a user no longer requires use of a licensed 
program 14, it transmits a RELEASE LICENSE request 
to the licensing policy module 15. The operations per- 
formed by the licensing policy module depend on the ba- 
sis for permitting usage of the licensed program. If usage 
was permitted as a result of a group license, if the group 
license is limited by usage, the licensing policy module 
1 5, if necessary, adjusts the records in the group license 
tables 17 related to the group license to reflect the fact 
that the licensed program 1 4 related to the group license 
is not being used. If the usage was pennitted as a result 
of a group license which is not limited by usage, but in- 
stead is limited in duration, or if the usage was permitted 
in response to the licensor's licensing policies, the licens- 
ing policy module 15 need do nothing. If the licensing 
policy module 15 maintains a log of usage outside the 
scope of a group or program license, it may make an 
entry in the log of the RELEASE request. 

Finally, if usage was peonitted as a result of the li- 
cense management facility 10 providing an approve us- 
age response to the GRANT LICENSE request, the li- 
censing policy module 15 transmits the RELEASE LI- 
CENSE request to the operating system 1 3. In response, 
the operating system 13 transfers the RELEASE LI- 
CENSE request to the license management facility 10, 
along with an identification of the system 16 using the 
licensed program 14. The license management facility 
10 then obtains from the license data base the identifi- 
cation of the appropriate license usage allocation unit 
value table in license unit tables 12. and determines the 
number of allocation units associated with this use of the 
licensed program 14 based on the identified allocation 
table and the processor. The license management facil- 
ity 10 then adjusts the number of license units for the 
licensed program 1 4 in the license data base 1 1 to reflect 
the release. 

it will be appreciated by those skilled in the art that, 
the license management facility 10 may. in response to 
a GRANT LICENSE request, instead of deducting alto- 
cation units from the entries in the license data base 11 
associated with the licensed programs 1 4, determine the 
number of albcation units which would be in use if usage 
of the licensed program 14 is permitted, and resportd 
based on that determination. If the license mangement 
facility 10 operates in that manner, it may be advanta- 
geous for the entries in license data base 11 relating to 
each licensed program 14 to maintain a running record 
of the number of allocatbn units associated with its us- 
age. The licensing policy module 15 may operate simi- 
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larly in connection with group licenses that are limited by 
usage. 

It will also be appreciated that the new license man- 
agement system thus permits the digital data processing 
system to control use of a licensed program 14 based 
on licensing criteria in the license data base 11, the li- 
cense unit tables 12, the group licensing tables 17 and 
the licensor's general licensing policies rather than re- 
quiring an operator to limit or restrict use of a licensed 
program or charging for the license based on some func- 
tion the capacity of all of the processors in the digital 
data processing system. The new license management 
system allows for very flexible pricing of licenses and li- 
censing policies, since the digital data processing sys- 
tem itself enforces the licensing terms controlling use of 
the licensed programs 14 in the system. 

Fig. 2 depicts the detailed structure of the license 
data base 11 (Fig. 1) used in the license management 
system depk:ted in Fig. 1 . With reference to Fig. 2, the 
license data base includes a plurality of entries generally 
identified by reference numberal 20, with each entry be- 
ing associated with one licensed program 1 4. Each entry 
20 includes a number of fields, including an issuer name 
field 21 identifying the issuer of the license, an authori- 
zation number field 22 which contains an authorization 
number, a producer name field 23 which identifies the 
name of the vendor of the licensed program, and a prod- 
uct name field 24 which contains the name of the li- 
censed program. The contents of these fields may be 
used, for example, in connection with other license man- 
agement operations, such as determining the source of 
licensed programs in the event of detection of errors in 
programs, and in locating duplicate entries in the license 
data base or entries which may be combined as a result 
of licenses being obtained and entered by, perhaps dif- 
ferent operators or at different times. 

Each entry 20 in the licensing data base 11 also in- 
cludes a license number field 25 whose contents identify 
the number of licensing units remaining. A license of a 
licensed program 14 identifies a number of licensing 
units, which may be a function of the price paid for the 
license. An availability table field 26 and an activity table 
field 27 identify license usage allocation unit value tables 
in the license unit tables 1 2 (described in connection with 
Fig. 3) to be used in connection with the GRANT LI- 
CENSE and RELEASE LICENSE requests. 

By way of background, a license may be in accord- 
ance with a licensing paradigm which requires concur- 
rent use of the licensed program 14 on several proces- 
sors to be a function of the processor power and capac- 
ity, and the availability table field 26 identifies a license 
usage allocation unit table to be used in connection with 
that. In an alternative, a license may be in accordance 
with a licensing paradigm which requires concun-ent use 
of the licensed program to be a function of the number 
of users using the program, and the activity table field 27 
identifies a license usage allocation unit valve table in 
the license unit tables 12 to be used in connection with 



that. If either licensing paradigm is used to the exclusion 
of the other, one field contains a non-zero value and the 
other field contains a zero value. In addition, a license 
may be in accordance with both licensing paradigms, 

5 that is, concurrent use of a program may be limited by 
b<^h processor power arKi capacity and by the number 
of concurrent users, and in that case both fields 26 and 
27 have non-zero values. 

In one embodiment of the licensing management 

10 system, fields 21 through 27 of an entry 20 in the licens- 
ing data base 11 are required. In that embodiment, an 
entry 20 in the licensing data may also have several op- 
tional fields. In particular, an entry 20 may include a 
date/version number field 30 whose contents comprise 

15 either a date or version number to identify the licensed 
program. If a license is to terminate on a specific date, 
the entry 20 may include a licensor temnination date field 

31 or a licensee termination date field 32 whose contents 
specify the termination date assigned by the licensor or 

20 licensee. TTiis may be particulariy useful, for example, 
as a mechanism for permitting licensees to demonstrate 
or try a program before committing to a long or open term 
license. 

Finally* an entry 20 in the license data base includes 
25 a checksum fieki 33, whk;h includes a checksum of the 
contents of the other fields 21 through 27 and 30 through 

32 in the entry 20, which may be established by means 
of a mathematical algorithm applied to the contents of 
the various fiekis. The general mechanism for establish- 

30 ing checksums is well known in the art, and will not be 
described further herein. The contents of all fiekJs 21 
through 27 and 30 through 33 of a new entry 20 are en- 
tered by an operator. Prior to establishment of an entry 
in the lk:ense data base 1 1 , the license management fa- 

3S cility 1 0 may verify correct entry of the information in the 
various fields by calculating a checksum and comparing 
it to the checksum provided by the operator. If the check- 
sum provided by the operator and the checksum deter- 
mined by the license management facility are the same, 

40 the entry 20 is established in the license data base 11. 
On the other hand, if the checksum provided by the op- 
erator and the checksum determined by the Ircense man- 
agement facility differ, the license management facility 
10 determines that the information is erroneous or the 

45 license is invalki and does not establish the entry 20 in 
the license data base 1 1 . It will be appreciated that, rf the 
checksum-generation algorithm is hidden from an oper- 
ator, the checksum provkles a mechanism for verifying, 
not only that the information has been properly baded 

50 Into the entry, but also that the license upon which the 
entry is based is authorized by the Ibensor. 

The structure of group license tables 1 7 may be sim- 
ilar to the structure of the license data base 11 , with the 
additbn that the entries for each Ircense reflected in the 

55 group license tables 17 will need to identify all of the li- 
censed programs covered thereby. 

As described above, the licensing unit tables 1 2 (Fig. 
1) contain informatkxi as to the allocatbn units for use 
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in determining the number of licensing units associated 
with use of a licensed program. The structure of a licens- 
ing unit table 40 is depicted in Fig. 3. With reference to 
Fig. 3, the licensing unit table includes a plurality of en- 
tries 41 (1) through 41 (N) (generally identified by refer- s 
ence numeral 41) each identified by a particular type of 
processor. One entry 41 in the table 40 is provided for 
each type of processor which can be included in the dig- 
ital data processing system which can use the licensed 
programs 14 which reference the license unit table 40. io 
The processor associated with each entry is identified by 
a processor identification field 42. The successive fields 
in the entries 41 (which form the various columns in the 
table 40 depicted In Fig. 3) fonm license usage allocation 
unit value tables 43(1) through 43(M) (generally identi- 
fied by reference numeral 43). The contents of the avail- 
ability table field 26 and the activity table field 27 identify 
a license usage allocation unit value table 43. If there are 
non-zero contents in both availability field 26 and activity 
field 27, the contents which identify be the same license 
usage allocation unit value table 43 or different license 2. 
usage allocation unit value tables 43. As described 
above, the contents of the license usage allocation unit 
value table identify the number of licensing units associ- 
ated with use of the licensed programs which identify the 
particular license usage allocation unit value table, for 
each of the identified processors. 

The operation of the licensing nnanagement system 
is depicted in detail in Figs. 4A-1 through 4-B. Figs. 4A-1 
through 4A-4 depict, in a number of steps the details dt 30 
operation of the licensing management system in con- 
nection with the GRANT LICENSE request from a li- 
censed program 14. Figs. 4B-1 and 4B-2 depict, in a 3. 
number of steps, the details of operation in connection 
with the RELEASE LICENSE request from a licensed 35 
program 14. In the Figs., the particular steps performed 
by the licensing policy nrxxJule 15. the license manage- 
ment facility 1 0 and the operating system 1 3 are indicat- 
ed in the respective steps. Since the operations depicted 
inFigs,4A-1 through 4B-2 are substantially as described 40 
above in connection with Fig. 1 , they will not be described 
further herein. 

The foregoing description has been limited to a spe- 
cific embodiment of this invention. It will be apparent, 
however, that variations and modifications may be made 45 
to the invention, with the attainment of some or all of the 
advantages of the invention. Therefore, it is the object of 
the appended claims to cover all such variations and 
modifications as come within the true scope of the inven- 
tion. 50 



Claims 

1 . A license management system for managing usage 55 
of a licensed software program (14), said license 
management system comprising a license manage- 
ment facility (10) responsive to a usage request to 



use said licensed software program, said license 
management system being characterized in that: 

said license management system comprises 
a license data base (11) for storing a licensing unit 
value identifying a number of licensing units associ- 
ated with the licensed sc^tware program (14), and 
further comprises a license unit table (1 2) for storing 
a plurality of usage allocation values identifying a 
number of licensing units associated with a plurality 
of respective uses of the licensed software program 
(14), and said license management facility (10) is 
responsive to a usage request to use said licensed 
software program (1 4) by determining, based on the 
contents of said license data base (11) and said 
license unit table (12), whether usage of said 
licensed sofhvare program (14) is permitted and, if 
usage is permitted, by adjusting the contents of said 
license data base (1 1 ) by a value related to the con- 
tents of said license unit table (12). 

A license rr^agement system as defined in claim 
1 for use in a digital data processing system which 
generates a system date value, wherein said license 
data base (11 ) includes a plurality of fields Including 
a licensing unit storage field (25) for storing said 
licensing unit value and a field (31 , 32) identifying a 
termination date, said license management facility 

(10) further determining whether usage of said 
licensed software program (14) is permitted in 
response to a comparison of said system date and 
said termination date. 

A license management system as defined in claim 
1 for managing usage of a plurality of licensed soft- 
ware programs (1 4), wherein said license data base 

(1 1 ) includes a plurality of entries (20) each contain- 
ing a program identification field (24) identifying a 
licensed software program (14) and a licensing unit 
storage field (25) for storing said licensing unit value, 
said license management facility (10) including: 

A. request receiving means for receiving a 
usage request identifying a licensed software 
program (14); 

B. licensing unit retrieval means responsive to 
receipt of a usage request by said request 
receiving means for retrieving the contents of 
said licensing unit storage field (25) from the 
entry (20) of said license data base (11) whose 
program identification field (24) identifies the 
licensed software program (1 4) identified in said 
usage request; and 

C. licensing unit processing means for deter- 
mining, based on the retrieved contents of said 
licensing unit storage field (25) and said license 
unit table (12), whether usage of said licensed 
software program (14) is permitted and, if usage 
is permitted, for adjusting the contents of said 
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license data base ( 1 1 ) by a value related to the 8. 
contents of said license unit table (12), 



4. A license management system as defined in claim 

3 for use in a digital data processing system which 5 
generates a system date value, each entry (20) in 
said license data base (1 1 ) further including a termi- 
nation date field (31, 32) identifying a termination 
date, said licensing unit processing means further 
determining whether usage of said licensed scrft- 
ware program (14) is permitted in response to a 
comparison of said system date and said termina- 
tion date. 

5. A license management system as defined in claim 
3 wherein said license unit table (1 2) includes a plu- 
rality of usage allocation tables (43) each storing a 
value identifying a number of licensing units, each 
entry (20) in said license data base (11) further 
including a usage allocation table identification field 
(26, 27) identifying a usage allocation table (43), 
said license management facility (10) further includ- 
ing usage allocation table retrieval means respon- 
sive to receipt by said request receiving means of a 
usage request for retrieving the contents of the 
usage allocation table (43) identified by the contents 
of said usage allocation table identification field (26, 
27) of said retrieved entry (20), said licensing unit 
processing means using said retrieved usage allo- 
cation table (43) in its determination. 

6. A license management system as defined in claim 
5 wherein a request message further includes 
licensing usage allocation value selection criteria 
and each usage allocation table (43) includes a plu- 
rality of entries (41 ) each identifying a usage alloca- 
tion value associated with a licensing usage alloca- 
tion value selection criterion, said license mar^ge- 
ment facility (1 0) including means for retrieving, from 
the usage allocation table (43) identified by said 
entry (20) in said license data base (1 1 ), the usage 
allocation value associated with the licensing usage 
allocatbn value selection criterion in said request 
message and using said retrieved usage allocation 
value in its determination. 

7. A license management system as defined in claim 
3 wherein a request message further includes 
licensing usage allocation value selection criteria 
and said usage allocation table (43) includes a plu- 
rality of entries (41 ) each identifying a usage alloca- 
tion value associated with a licensing usage alloca- 
tion selection criterion, said license management 
facility (10) including means for retrieving the usage 
allocation value associated with the licensing usage 
allocation selectbn criterion in said request mes- 
sage and using said retrieved usage allocation value 
in its determinatbn. 



9. A license management system as defined in daim 

8 for managing usage of a plurality of licensed soft- 
ware programs (14), wherein said license data base 
(1 1 ) includes a plurality of entries (20) each contain- 
ing a program identification field (24) identifying a 
licensed software program (14) and a licensing unit 
storage field (25) for storing said licensing unit value, 
said license management facility (10) including: 

A. request receiving means for receiving a 
release request identifying a licensed software 
program (14): 

B. licensing unit processing means for adjusting 
the contents of said license data base (1 1 ) by a 
value related to the contents of said license unit 
table (12). 

10. A license management system as defined in claim 

9 wherein said license unit table (1 2) includes a plu- 
rality of usage allocatbn tables (43) each storing a 
value identifying a number of licensing units, each 
entry (20) in said Ibense data base (11) further 
including a usage allocation table identification field 
(26, 27) identifying a usage allocation table (43), 
said license management facility (10) further includ- 
ing usage allocation table retrieval means respon- 
sive to said request receiving means receipt of a 
usage request for retrieving the contents of the 
usage allocation table (43) identified by the contents 
of said usage allocation table identiTication field (26, 
27) of said retrieved entry (20), said licensing unit 
processing means using said retrieved usage allo- 
catbn table (43) in its adjusting. 

11. A license management system as defined in claim 
b wherein a release message further includes 
Ibensing usage allocation value selection criteria 
and each usage allocation table (43) includes a plu- 
rality of entries (41 ) each identifying a usage alloca- 
tion value associated with a licensing usage alloca- 
tion value selection criterbn, said license manage- 
ment facility (10) including means for retrieving, from 
the usage allocation table (43) identified by said 
entry (20) in said Ibense data base (11), the usage 
allocation value associated with the Ibensing usage 
allocation value selection criterion in said request 
message and using said retrieved usage allocation 
value in its adjusting. 

12. A license management system as defined in daim 
8 wherein a release message further includes 



A license management system as defined in daim 
1 wherein said Ibense nnanagement facility (1 0) fur- 
ther operates in response to a release request mes- 
sage for adjusting the contents of said Ibense data 
base (11) by a value related to the contents of said 
license unit table (12). 
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licensing usage allocation value selection criteria 
and each usage allocation table (43) includes a plu- 
rality of entries (41 ) each identifying a usage alloca- 
tion value associated with a licensing usage alloca- 
tion value selection criterion, said license nnanage- 5 
ment facility (1 0) including means tor retrieving, from 
the usage allocation value table identified by said 
entry (20) in said license data base (1 1 ), the usage 
allocation value associated with the licensing usage 
allocation value selection criterion in said request 
message and using said retrieved usage allocation 
value in Its adjusting. 

13. A method of managing licenses in a digital data 
processing system, said method comprising the ^5 
step of responding, through use of a license man- 
agement facility (10), to a usage request to use a 
licensed software program (14), and said method 
further comprising the step of generating a system 
date value and comparing said system date value 20 
with a termination date to determine whether usage 
of said licensing software program (14) is pemnitted, 
said method being characterized by further compris- 
ing the steps of: 

25 

A. storing, in a license data base (11) including 
a plurality of entries (20) each associated with 
a licensed software program (14): 



license data base (11) the licensing table 
entry (20) associated with said licensed 
software program (14); 

iii. retrieving from said license unit table ( 1 2) 
a usage allocation entry (41 ) identified by 
said retrieved licensing table entry (20) and 
the licensing usage allocation value selec- 
tion criterion identified by the received 
usage request message: and 

iv. processing said usage request by: 

(a) comparing the contents of said 
licensing units field (25) and said usage 
allocation units field (41 ) and date com- 
parison means in order to compare the 
system date value with the contents of 
said termination date field (31 , 32) to 
determine whether usage of said 
licensing software program (14) is per- 
mitted; 

(b) generating a message in response 
to the determination by said usage 
determination means; and 

(c) adjusting the contents of said 
licensing units field (25) in response to 
a positive detemnination by said usage 
determination means; and 

D. releasing usage, using said license manage- 
ment facility (10), by: 

i. receiving a usage request message at 
said license management facility (10) from 
a licensed software program (14), said 
usage request message identifying said 
licensed software program (14) and usage 
grant criteria; 

ii. responding to the receipt of a usage 
request message by retrieving from said 
license data base (11) the licensing table 
entry (20) associated with said licensed 
software program (14); 

iii. retrieving from said license unit table (12) 
a usage allocation entry (41) identified by 
said retrieved licensing table entry (20) and 
the licensing usage allocation value selec- 
tion criterion identified by the received 
usage request massage; and 

iv. adjusting the contents of said licensing 
units field in relation to the value of said 
usage allocation entry (41 ). 



Patentanspruche 

1. Lizenz-Managementsystem zur Verwaltung der 
Benutzung eines lizensierten Software-Programms 
(14), wobei das Lizenz-Managementsystem eine 



a licensing unit value, in a licensing unrtfield 30 
(25) of each entry (20), identifying a number 
of licensing units associated with the 
licensed software program (14), 
an identification of a usage allocation table 
(43), in a usage allocation table identifica- 3S 
tion field (26, 27) of each entry (20), and 
a tenmination date, in a termination date 
field (31 , 32) of each entry (20); 

B. storing, in a license unit table (1 2), a plurality ^ 
of usage allocation tables (43), each usage allo- 
cation table (43) having a plurality of usage allo- 
cation entries (41), each usage allocation entry 
(41) being associated with a licensing usage 
allocation value selection criterion and including 

a usage allocation value identifying a number of 
licensing units; 

C. granting usage, using a license management 
facility (10), by: 

so 

i. receiving a usage request message at 
said license management facility (10) from 
a licensed software program (14), said 
usage request message identifying said 
licensed software program (14) and usage 5S 
grant criteria; 

ii. responding to the receipt of a usage 
request message by retrieving from said 
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Lizenz-Managementeinrichtung (10) aufweist, die 
auf eine Benutzungsanforderung zur Benutzung 
des lizensierten Software-Programms ansprtcht, 
wobei das Lizenz-Managementsystem dadurch 
gekennzetchnet ist, daf3: 

das Lizenz-Managementsystem eine Lizenz- 
Datenbank (11) zur Speicherung eines Lizenzein- 
heit-Wertes aufweist, der eine Anzahl von Lizenz- 
einheiten identifiziert, die dem lizensierten Soft- 
ware-Programm (14) zugeordnet sind, und das wei- 
terhin eine Lizenzeinheit-Tabelle (12) zur Speiche- 
rung einer Vielzahl von Benutzungszutellungswer- 
ten aufweist, die eine Anzahl von Lizenzeinheiten 
identifizieren, die einer Vielzahl entsprechender 
Benutzungen des lizensierten Software-Programms 
(14) zugeordnet sind, und dadurch, daB die 
Lizenz-Managementeinrichtung (10) auf eine 
Benutzungsanforderung zur Benutzung des lizen- 
sierten Software-Programms (14) ansprtcht, indem 
sie auf der Basis der Inhatte der Lizenz-Datenbank 
(11) und der Lizenzeinheit-Tatselle (12) ermittett, ob 
die Benutzung des lizensierten Software-Pro- 
graiTims (14) eriaubt ist und indem sie, falls die 
Benutzung eriaubt ist, den Inhalt der Lizenz-Daten- 
bank (11) durch einen Wert einstelft. der mit dem 
Inhalt der Lizenzeinheit-Tabelle (12) in Beziehung 
steht. 

Lizenz-Managementsystem nach Anspruch 1 zur 
Verwendung in elnem einen Systemdatumswert 
erzeugenden digitalen Datenverarbeitungssystem, 
bei dem die Lizenz-Datenbank (11) eine Vielzahl 
von Feldern einschlieBlich einem Lizenzein- 
helt-Spetcherfeld (25) zur Speicherung des Lizenz- 
einheit-Wertes sowie einem Feld (31 , 32) aufweist, 
das ein Ablaufdatum kientifiziert, wobei die 
Lizenz-Managementeinrichtung (10) entsprechend 
einem Verglebh des Systemdatums mit dem Ablauf- 
datum weiterhin enmittelt, ob die Benutzung des 
lizensierten Software-Programms (14) eriaubt ist. 

Lizenz-Managementsystem nach Anspruch 1 zur 
Venwaltungder Benutzung einer Mehrzaht lizensier- 
ter Software-Programme (14), bei dem die 
Lizenz-Datenbank (11) eine Vielzahl von Eintragen 
(20) aufweist, die jeweils ein Programm-kientifikati- 
onsfekJ (24), das ein lizensiertes Software-Pro- 
gramm (14) kJentifiziert, und ein Lizenzeinheit-Spei- 
cherfeld (25) zur Speicherung des Ltzenzein- 
heit-Wertes enthatten, wobei die Lizenz-Manage- 
menteinrichtung (10) folgendes aufweist: 

A. eine Anforderungs-Empfangseinrk^htung 
zum Empfangen einer Benutzungsanforde- 
rung, die ein lizensiertes Software-Programm 
(14) kientifiziert; 

B. eine Lizenzeinhert-Abrufeinrichtung, die auf 
den Empfang einer Benutzungsanforderung 



durch die Anforderungs-Empfangseinrichtung 
ansprlcht, um den Inhaft des Lizenzein- 
heit-Spek:herfeldes (25) vom Eintrag (20) der 
Lizenz-Datenbank (ll)abzuruf en, dessen Pro- 

5 gramm-kJentifikatonsfekj (24) das lizensierte 

Software-Programm (14) identifiziert, das in der 
Benutzungsanforderung klentifiziert wurde; und 
C. eine Lizenzeinheit-Verarbeitungseinrk:h- 
tung, um auf der Basis der abgerufenen Inhatte 

10 des Lizenzeinheit-Spercherfekjes (25) und der 

Lizenzeinheit-Tabelle (12) zu ermittein, ob die 
Benutzung des lizensierten Software-Pro- 
gramms (14) eriaubt ist, und, falls die Benut- 
zung eriaubt ist, um den Inhalt der 

IS Lizenz-Datenbank (1 1 ) durch einen Wert einzu- 

stellen, der mit dem Inhalt der Lizenzein- 
heit-Tabelle (12) in Beziehung steht 

4. Lizenz-Managementsystem nach Anspruch 3 zur 
20 Verwendung in einem einen Systemdatumswert 

erzeugenden digitalen Datenverarbeitungssystem, 
wobei jeder Eintrag (20) in der Lizenz-Datenbank 
(11) weiterhin ein Ablaufdatum-FekJ (31, 32) auf- 
weist, das ein Ablaufdatum kientifiziert. wobei die 
2S Lizenzeinheit-Verarbeitungseinrichtung entspre- 
chend einem Vergleich des Systenndatums mit dem 
Ablaufdatum weiterhin enmittelt, ob die Benutzung 
des lizensierten Software-Programms (14) eriaubt 
ist 

30 

5. Lizenz-Managementsystem nach Anspruch 3, bei 
dem die Lizenzeinheit-Tabelle (12) eine Vielzahl von 
Benutzungszuteilung-Tabellen (43) aufweist, die 
jeweils einen Wert spechem, der eine Anzahl von 

35 Lizenzeinheiten kientifiziert, wobei jeder Eintrag 
(20) in der Lizenz-Datent>ank (11) weiterhin ein 
Benutzungszuteilungstabelle-ldentifikatkxisfekJ 
(26, 27) aufweist, das eine Benutzungszutet- 
lungs-Tabelle (43) kientifiziert, wobei die Lizenz- 

^ Managementeinrichtung (10) weiterhin eine Benut- 
zungszuteilungstabelle-Abrufeinrbhtung aufweist, 
die auf den Empfang einer Benutzungsanforderung 
durch die Anforderungs-Empfangseinrichtung 
anspricht, um den Inhalt der Benutzungszutei- 

45 lungs-Tabelle (43) abzurufen, die durch den Inhalt 
des Benutzungszuteilungstabelie-ldentifikationsfel- 
des (26, 27) des abgerufenen Eintrags (20) identifi- 
ziert wurde, wobei die Lizenzeinheit-Verarbertungs- 
einrichtung die abgerufene Benutzungszutei- 

50 lungs-Tabelle (43) zur Ermittlung venwendet. 

6. Lizenz-Managementsystem nach Anspruch 5, bei 
dem eine Anforderungsnachrk^ht weitertiin Lizenz- 
Benutzungszuteilungswert-Auswahlkriterien auf- 

55 weist und jede Benutzungszuteilungs-Tabelle (43) 
eine Vielzahl von Eintragen (41 ) aufweist, die jeweils 
einen Benutzungszuteilungswert kJentifizieren, der 
einem Lizenz-Benutzungszuteilungswert-Auswahl- 
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kriterium zugeordnet ist, wobei die Lizenz-Manage- 
menteinrichtung (10) eine Etnrichtung aufweist, um 
aus der Benutzungszuteilungs-Tabelle (43), die 
durch den Eintrag (20) In der Lizenz-Datenbank (1 1 ) 
identifiziert wurde, den Benutzungszuteilungswert 
abzurufen, der dem Lizenz-Benutzungszuteilungs- 
wert-Auswahlkriterium in der Anforderungsnach- 
richt zugeordnet ist, und um den abgerufenen 
Benutzungszuteilungswert zur Enmittlung zu ver- 
wenden. 

7. Lizenz-Managementsystem nach Anspruch 3, be! 
dem eine Anforderungsnachricht weitertiin Lizenz- 
Benutzungszuteilungswert-Auswahlkrrterlen auf- 
weist und die Benutzungszuteilungs-Tabelle (43) eine 
Vielzahl von Eintragen (41 ) aufweist, die jeweils einen 
Benutzungszuteilungswert kJentifizieren, der einem 
Lizenz-Benutzungszutellungswert-Auswahlkriterium 
zugeordnet ist, wobei die Lizenz-Managementein- 
richtung (10) eine Einrlchtung aufweist, um den 
Benutzungszuteilungswert abzurufen, der dem 
Lizenz-Benutzungszuteilungswert-Auswahlkriterium 
in der Anforderungsnachricht zugeordnet ist, und um 
den abgerufenen Benutzungszuteilungswert zur 
Ermittlung zu venwenden 

8. Lizenz-Managementsystem nach Anspruch 1. bei 
dem die Lizenz-Managementeinrichtung (10) wei- 
terhin entsprechend einer Freigabe-Anforderungs- 
nachrbht arbertet, um den Inhalt der Lizenz-Daten- 
bank (11) durch einen Wert zu andern. der mit dem 
Inhalt der Lizenzeinheit-Tabelle (12) in Beziehung 
steht. 

9. Lizenz-Managementsystem nach Anspruch 8 zur 
Verwaltung der Benutzung einer Mehrzahl lizensier- 
ter Software-Programme (14). bei dem die Lizenz- 
Datenbank (11) eine Vielzahl von Eintragen (20) auf- 
weist, die jeweils ein Programm-ldentifikatkxisfeld 
(24), das ein lizensiertes Software-Programm iden- 
tifiziert, und ein Lizenzeinheit-Speicherfeld (25) zur 
Speicherung des Lizenzeinhert-Wertes enthatten, 
wobei die Lizenz-Managementeinrichtung (10) fol- 
gendes aufweist: 

A. eine Anforderungs-Empfangseinrichtung 
zum Empfangen einer Freigabeanforderung. 
die ein lizensiertes Soft^re-Programm (14) 
identifiziert; 

B. eine Lizenzeinhert-Verarbeitungseinrichtung 
zum Einstellen des Inhalts der Lizenz-Daten- 
bank (11) durch einen Wert, der mit dem Inhalt 
der Lizenzeinheit-Tabelle (12) in Beziehung 
steht. 

10. Lizenz-Managementsystem nach Anspruch 9, bei 
dem die Lizenzeinheit-Tabelle (1 2) eine Vielzahl von 
Benutzungszuteilungs-Tabellen (43) aufweist, die 



jeweils einen Wert speichem, der eine Anzahl von 
Lizenzeinheiten klentifiziert, wobei jeder Eintrag 
(20) in der Lizenz-Datenbank (11) weiterhin ein 
Benutzungszuteilungstabelle-I dentrfi kationsf eld 

s (26, 27) aufweist, das eine Benutzungszuteilungs- 
Tabelle (43) identifiziert, wobei die Lizenz-Manage- 
menteinrk:htung (10) weiterhin eine Benutzungszu- 
teilungstabelle-Abrufeinrichtung aufweist. die auf 
den Empfang einer Benutzungsanforderung durch 

10 die Anforderungs-Empfangseinrk^htung anspricht, 
um den Inhalt der Benutzungszuteilungs-Tabelle 
(43) abzurufen, die durch den Inhalt des Benut- 
zungszuteilungstabelle-kientifikatbnsfeldes (26. 
27) des abgerufenen Eintrags (20) identifiziert 

IS wurde, wobei die Lizenzeinheit-Verarbeitungsein- 
nchtung die abgerufene Benutzungszutei- 
lungs-Tabelle (43) zum Einstellen verwendet 

11. Lizenz-Managementsystem nach Anspruch 10. bei 
20 dem eine Freigabenachricht weiterhin Lizenz- 

Benutzungszuteilungswert-Auswahlkriterien auf- 
weist und jede Benutzungszuteilungs-Tabelle (43) 
eine Vielzahl von Eintragen (41 ) aufweist, die jeweils 
einen Benutzungszuteilungswert kjentrfizieren. der 

25 einem Lizenz-Benutzungszuteilungswert-Auswahl- 
kriterium zugeordnet ist, wobei die Lizenz-Manage- 
menteinrichtung (10) eine Einrichtung aufweist, um 
aus der Benutzungszuteilungs-Tat)elle (43), die 
durch den Eintrag (20) in der Lizenz-Datenbank (11) 

30 identifiziert wurde, den Benutzungszuteilungswert 
abzurufen, der dem Lizenz-Benutzungszuteilungs- 
wert-Auswahl kriterium in der Freigabenachrfcht 
zugeordnet ist, und um den abgerufenen Benut- 
zungszuteilungswert zum Einstellen zu verwenden. 

55 

12. Lizenz-Managementsystem nach Anspruch 8, bei 
dem eine Freigabenachricht weiterhin Lizenz- 
Benutzungszuteilungswert-Auswahlkriterien auf- 
weist und jede Benutzungszuteilungs-Tabelle (43) 

40 eine Vielzahl von Eintragen (41 ) aufweist, die jeweils 
einen Benutzungszuteilungswert identiTizieren, der 
einem Lizenz-Benutzungszuleilungswert-Auswahl- 
krrterium zugeordnet ist. wobei die Lizenz-Manage- 
menteinrk:htung (10) eine Einrichtung aufweist, um 

^ aus der Benutzungszuteilungs-Tabelle (43), die 
durch den Eintrag (20) in der Lizenz-Datenbank (11) 
kJentifiziert wurde, den Benutzungszuteilungswert 
abzurufen, der dem Lizenz-Benutzungszuteilungs- 
wert-Auswahlkrrterium in der Anforderungsnach- 

50 richt zugeordnet ist, und um den abgerufenen 
Benutzungszuteilungswert zum Einstellen zu ver- 
wenden. 

13. Verfahren zum Venwalten von Lizenzen in einem 
55 digitalen Datenverarbeitungssystem, wobei das 

Verfahren den Schritt aufweist, durch die Venwen- 
dung einer Lizenz-Managementeinrichtung (10) auf 
eine Benutzungsanforderung zur Benutzung eines 
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lizensierten Software-Programms (14) zu antwor- 
ten, und wobei das Verfahren weitertiin den Schritt 
aufweist, einen Systemdatumswert zu erzeugen 
und diesen Systemdatumswert mit einem Ablaufda- 
tum zu vergleichen, um zu emnitteln, ob die Benut- s 
zung des lizensierten Software-Programms (14) 
eriaubt ist, wobei das Verfahren dadurch gekenn- 
zeichnet ist, da3 es werterhin die Schritte aufweist, 

A. in einer Lizenz-Datenbank (1 1 ), die eine Viet- io 
zahl von Eintragen (20) aufweist, die jeweils 
einem lizensierten Software-Programm (14) 
zugeordnet sind, folgendes zu speichem: 

einen Lizenzeinheit-Wert in einem Lizenz- 
einheit-Feld (25) jedes Eintrags (20), wobei ^5 
dieser Wert eine Anzahl von Lizenzeinhei- 
ten identifiziert, die dem lizensierten Soft- 
ware-Programm (14) zugeordnet sind, 
eine Identifikation einer Benutzungszutet- 
lungs-Tabelle (43) in einem Benutzungszu- 20 
teilungs-Tabelle-ldentifikattor^feld (26, 
27), und 

ein Ablaufdatum in einem Ablaufda- 
tum-Feld (31, 32) jedes Eintrags (20); 

25 

B. in einer Lizenzeinheit-Tabetle (1 2) eine Viel- 
zaht von Benutzungszuteilungs-Tabellen (43) 
zu speichem, wobei jede Benutzungszutei- 
lungs-Tabelle (43) eine Vielzahl von Benut- 
zungszutellungs-Eintragen (41 ) aufweist, wobei 30 
jeder Benutzungszuteilungs-Eintrag (41 ) einem 
Lizenz-Benutzungszuteilungswert-Auswahlkri- 
terium zugeordnet ist und einen Benutzungszu- 
teilungswert aufweist, der eine Anzahl von 
Lizenzeinheiten identifiziert; 35 

C. unter Verwendung einer Lizenz-Manage- 
menteinrichtung (10) die Benutzung zu gewah- 
ren, indem: 

i. an der Lizenz-Managementeinrichtung 40 
(10) eine Benutzungsanforderungs-Nach- 
richt von einem lizensierten Software-Pro- 
gramm (14) empfangen wird, wobei die 
Benutzungsanforderungs-Nachricht das 
lizensierte Software-Programm (14) und 45 
Benutzungsgewahrungs-Kriterien kJentifi- 
ziert; 

ii. auf den Empfang einer Benutzungsanfor- 
derungs-Nachricht geantwortet wird, indem 
aus der Lizenz-Datenban k ( 1 1 ) der Lizenz- 50 
tabelleneintrag (20) abgerufen wird, der 
dem lizensierten Software-Programm (1 4) 
zugeordnet ist; 

iii. aus der Lizenzeinheit-Tabelle (12) einen 
Benutzungszuteilungs-Eintrag (41), der 55 
durch den abgerufenen Lizenztabellenein- 
trag (20) kjentiftziert wurde, und das 
Lizenz-Benutzungszuteilungswert-Aus- 



wahlkriterium abgerufen wird. das durch 
die empfangene Benutzungsanforderungs- 
Nachricht identifiziert wurde; und indem 
iv. die Benutzungsanforderung verarbeitet 
wird durch: 

a) Vergleichen der Inhalte des Lizenz- 
einhert-Feldes (25), des Benutzungs- 
zuteilungseinhert-FekJes (41) und der 
Datums-Vergletchseinrichtung, umden 
Systemdatumswert mIt dem Inhatt des 
Ablaufdatum-Fekjes (31, 32) zu ver- 
glek:hen, umzu enmittein, obdie Benut- 
zung des lizensierten Software-Pro- 
gramms (14) eriaubt ist; 

b) Erzeugen einer Nachricht entspre- 
chend der Enmittlung durch die Benut- 
zungsermrttlungseinrlchtung; und 

c) Andem des Inhalts des Lizenzein- 
heit-Feldes (25) in Reaktion auf eine 
positive Ermittlung durch die Benut- 
zungsermittlungseinrichtung; und 

D. unter Venvendung der Lizenz-Manage- 
menteinrichtung (10) die Benutzung freizu- 
geben, indem: 

i. an der Lizenz-Managementeinrich- 
tung (10) eine Benutzungsanforde- 
rungs-NachrkJht von einem lizensier- 
ten Software-Programm (14) empfan- 
gen wird, wobei die Benutzungsanfor- 
derungs-Nachricht das lizensierte 
Software-Programm (14) und Benut- 
zungsgewahrungs-Kriterien identifi- 
ziert; 

ii. auf den Empfang einer Benutzungs- 
anforderungs-Nachrbht geantwortet 
wird, indem aus der Lizenz-Datenbank 
(11) der Lizenztabelleneintrag (20) 
abgerufen wird, der dem lizensierten 
Software-Programm (14) zugeordnet 
ist; 

iii. aus der Lizenzeinheit-Tabelle (12) 
ein Benutzungszuteilungseintrag (41 ), 
der durch den abgerufenen Lizenzta- 
belleneintrag (20) kientrfiziert wurde, 
und das Lizenz-Benutzungszutei- 
lungswert-Kriterium abgerufen wird, 
das durch die empfangene Benut- 
zungsanforderungs-Nachricht identifi- 
ziert wurde; und indem 

iv. der inhatt des Lizenzeinheit-Feldes 
in Relatbn zum Wert des Benutzungs- 
zuteilungseintrags (41) geandert wird. 
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qui agissent en rdponse ^ la reception d'une 
demande d'usage par lesdits moyens r6cep- 
teurs de demande pour extraire le contenu de 
ladrte zone de stockage d'unit^ de licence (25) 
5 de I'entr^e (20) de ladite base de donn^es de 

licence (11), dont la zone d'identification de pro- 
gramme (24) identifie le programme logiciel 
sous licence (1 4) identifi6 dans ladrte demande 
d'usage; et 

10 c. des moyens de traitement d'unit^ de licence 

destines h d^emiiner, en fonction du contenu 
extrait de ladite zone de stockage d'unit^s de 
licence (25) et de ladite table d'unitds de licence 
(12), si I'usage dudit programme logiciel sous 

IS licence (1 4) est autoris6 et, dans Taffirmative, k 

ajuster le contenu de ladite base de donndes de 
licence (11) au moyen d'une valeur en relation 
avec le contenu de ladite table d'unit^ de 
licence (1 2). 

20 

4. Syst^e de gestbn de licences tel que defini dans 
la revendlcation 3, destin6 k dtre utilise dans un sys- 
t^me de traitement de donnees num6riques g6n6- 
rant une valeur de date de syst^e, chaque entrde 

25 (20) de ladite base de donnees de licence (11) com- 
prenant, en outre, une zone de date d'interruptk»n 
(31, 32) qui identifie une date cf interruption, lesdits 
moyens de traitement d'unit6s de Ircence determi- 
nant 6galement si I'usage dudit programme logiciel 

30 sous licence (14) est autoris6, en r6ponse k une 
comparaison de ladite date de systdme et de ladite 
dale d'interruption. 

5. Syst^e de gestbn de lk:ences tel que dSfini dans 
35 la revendlcation 3, dans lequel ladite table d'unit^s 

de licence (12) comprend plusieurs tables d'attribu- 
tion d'usage (43) qui stockent chacune une valeur 
kientifiant un nombre d'unit6s de licence, chaque 
entree (20) de ladite base de donn6es de Ibence 

40 (11) contenant 6galement une zone d'kjentificatbn 
de table d'attributbn d'usage (26, 27) qui kientifie 
une table d'attributk>n d'usage (43). ledit gestk>n- 
naire de lk;ences (10) comprenant. en outre, des 
moyens d'extractbn de table d'attributk)n d'usage 

45 qui agissent en r6ponse k la r^ceptbn d'une 
demande d'usage par lesdits moyens r^cepteurs de 
demande, pour extraire le contenu de la table d'attri- 
butk)n d'usage (43) identifi6e par le contenu de 
ladite zone d'identificatkTn de table d'attribution 

50 d'usage (26, 27) de ladite entree (20) extraite, lesdits 
moyens de traitement d'unitds de lk;ence utilisant, 
pour leur determination, ladite table d'attributbn 
d'usage (43) extraite. 



Revendications 

1. Systeme de gestbn de lk:ences pour g^rer I'usage 
d'un programme logiciel sous licence (14), ledit sys- 
t6me de gestbn de licences comprenant un gestkjn- 
naire de Ibences (10) qui agit en rdponse k une 
demande d'usage pour utiliser ledit programme logi- 
ciel sous Ircence, ledit systdme de gestbn de licen- 
ces etant caracterise en ce que : 

ledit systeme de gestion de licences com- 
prend une base de donn6es de Ibence (11) destin§e 
k stocker une valeur d'unitds de Ibence bentlftant 
un nombre d' unites de licence associ^es au pro- 
gramme bgiciel sous licence (14), et egalement une 
table d'unites de Ibence (1 2) destin^e k stocker plu- 
sieurs valeurs d'attributbn d'usage bentifiant un 
nombre d'unit^s de Ibence associ^es k plusieurs 
utilisations respectives du programme logiciel sous 
licence (1 4), ledit gestbnnaire de Ibences (10) agis- 
sant en r^ponse k une denoande d'usage pour utili- 
ser ledit programme bgbiel sous Ibence (14) en 
determinant, en fonctbn du contenu de ladite base 
de donnees de licence (1 1 ) et de ladite table d'unites 
de licence (12), si I'usage dudit programme bgbiel 
sous Ibence (14) est autorise et, dans I'affirmative, 
en ajustant le contenu de ladite base de donnees de 
licence (1 1 ) au moyen d'une valeur en relation avec 
le contenu de ladite table d'unites de licence (12). 

2. Systdme de gestbn de licences tel que defini dans 
la revendicatbn 1 , destine k etre utilise dans un sys- 
tdme de traitement de donnees numeriques gene- 
rant une valeur de date de systdme, dans lequel 
ladite base de donnees de licence (1 1 ) contient plu- 
sieurs zones comprenant une zone de stockage 
d'unites de Ibence (25) destinee k stocker ladite 
valeur d'unites de licence, et une zone (31, 32) qui 
bentifie une date d'interruptbn, ledit gestbnnaire de 
licences (10) determinant, en outre, si I'usage dudit 
programme logbiel sous Ibence (14) est autorise, 
en reponse k une comparaison de ladite date de 
systdme et de ladite date d'interruptbn. 

3. Systdme de gestbn de licences tel que ddfini dans 
la revendicatbn 1 , pour gerer I'usage de plusieurs 
programmes logiciels sous Ibence (14), dans lequel 
ladite base de donnees de licence (1 1 ) comprend 
plusieurs entrdes (20) contenant chacune une zone 
d'identification de programme (24) qui identifie un 
programme logbiel sous licence (14), et une zone 
de stockage d'unitds de licence (25) destinee k stoc- 
ker ladite valeur d'unites de Ibence (25), ledit ges- 
tionnaire de Ibences (10) comprenant : 

A. des moyens recepteurs de dennande desti- 
nes k recevoir une demande d'usage identifiant 
un programme logiciel sous licence (14); 

B. des moyens extracteurs d'unites de licence 



55 6. Systdme de gestbn de Ibences tel que ddfini dans 
la revendication 5, dans lequel un message de 
demande comprend egalement des critdres de 
selection de valeur d'attributbn d'usage de licence. 
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et chaque table cfattribution d'usage (43) contient 
plusieurs entries (41) qui identrfient chacune une 
valeurd'attributton d'usage associ^e k un critdre de 
selection de valeur d'attribution d'usage de licence, 
ledit gestionnaire de licences (10) comprenant des s 
moyens pour extraire de la table d'attribution 
d'usage (43) identrfiSe par ladite entree (20) de 
tadite base de donn6es de licence (11) la valeur 
d'attribution d'usage associ6e au crit^re de selection 
de valeur d'attribution d'usage de licence dudrt mes- io 
sage de demande, et utilisant, pour sa determina- 
tion, ladite valeur d'attribution d'usage extraite. 

7. Systdme de gestion de licences tel que d6fini dans 
la revendication 3, dans lequel un message de 
demande comprend dgalement des critdres de 
selection de valeur d'attribution d'usage de licence, 
et ladite table d'attribution d'usage (43) contient plu- 
sieurs entries (41) qui identifient chacune une 
valeur d'attribution d'usage associ6e ^ un crtt^re de 20 
selection d'attribution d'usage de licence, ledit ges- 
tionnaire de licences (10) comprenant des moyens 
pour extraire la valeur d'attribution d'usage associde 

au entire de selection d'attribution d'usage de 
licence dudit message de demande. et utilisant, 2S 
pour sa determination, ladite valeur d'attributbn 
d'usage extraite. 

8. Systeme de gestion de licences tel que defini dans 

la revendication 1 . dans lequel ledit gestionnaire de 30 
licences (10) agit egalement en rdponse k un mes- 
sage de demande de rdsiliation pour ajuster le con- 
tenu de tadite base de donndes de licence (1 1 ) au 
moyen d'une valeur en relation avec le contenu de 
ladite table d'unit^s de licence (12). 3S 



de licence (1 2) comprend plusieurs tables d'attribu- 
tion d'usage (43) qui stockent chacune une valeur 
identifiant un nombre d'unit6s de licence, chaque 
entree (20) de ladite base de donnSes de licence 
(11) comprenant 6galement une zone d'identifica- 
tion de table d'attribution d'usage (26, 27) qui iden- 
tifie une table d'attribution d'usage (43), ledit ges- 
tionnaire de licences comprenant, en outre, des 
moyens d'extraction de table d'attribution d'usage 
qui agissent en rdponse k la reception d'une 
demande d'usage par lesdits moyens recepteurs de 
demande pour extraire ie contenu de la table d'attri- 
bution d'usage (43) tdentifiee par le contenu de 
ladite zone d'identification de table d'attribution 
d'usage (26, 27) de ladite entree (20) extraite, lesdits 
rTK>yens de traitement d'unites de licence utilisant, 
pour leur ajustement, ladite table d'attribution 
d'usage (43) extraite. 

11. Systeme de gestion de licences tel que defini dans 
la revendication 1 0, dans lequel un message de resi- 
liation comprend egalement des criteres de selec- 
tion de valeur d'attribution d'usage de licence, et 
chaque table d'attribution d'usage (43) contient plu- 
sieurs entrees (41) qui identifient chacune une 
valeur d'attribution d'usage associee k un critere de 
selection de valeur d'attribution d'usage de licence, 
ledit gestionnaire de licences (10) comprenant des 
moyens destines k extraire de la table d'attribution 
d'usage (43) identifiee par ladite entree (20) de 
ladite base de donnees de licence (11) la valeur 
d'attribution d'usage associee au critdre de selection 
de valeur d'attribution d'usage de licence dudit mes- 
sage de demande et utilisant, pour son ajustement, 
tadite valeur d'attribution d'usage extraite. 



9. Systeme de gestion de licences tel que defini dans 
la revendication 8, pour gerer I'usage de plusieurs 
programmes logiciels sous licence (1 4), dans lequel 
ladite base de donnees de licence (11) comprend 
plusieurs entrees (20) contenant chacune une zone 
d'identification de programme (24) qui identifie un 
programme logiciei sous licence (14), et une zone 
de stockage d'unites de licence (25) destinee k stoc- 
ker ladite valeur d'unites de licence, ledit gestion- 
naire de licences (10) comprenant : 

A. des moyens recepteurs de demande desti- 
nes k recevoir une demande de resiliation iden- 
tifiant un programme logiciei sous licence (14); 

B. des nrrayens de traitement d'unites de licence 
destines k ajuster le contenu de tadite base de 
donnees de licence (1 1 ) au nK>yen d'une valeur 
en relation avec le contenu de ladite table d'uni- 
tes de licence (12). 

10. Systeme de gestion de licences tel que defini dans 
la revendication 9, dans lequel tadite table d'unites 



12. Systeme de gestion de licences tel que defini dans 
la revendication 8, dans lequel un message de resi- 
liation comprend egalement des criteres de setec- 

40 tion de valeur d'attributkxi d'usage de licence, et 
chaque table d'attribution d'usage (43) contient plu- 
sieurs entrees (41) qui identrfient chacune une 
valeur d'attribution d'usage associee k un critere de 
seiectbn de valeur d'attributbn d'usage de licence, 

45 ledit gestionnaire de licences (1 0) comprenant des 
moyens pour extraire de ta table de valeur d'attribu- 
tion d'usage identifiee par ladite entree (20) de ladite 
base de donnees de licence (1 1 ) ta valeur d'attribu- 
tion cf usage associee au critere de selection de 

50 valeur d'attribution d'usage de licence dudit mes- 
sage de dennande et utilisant. pour son ajustement, 
ladite valeur d'attribution d'usage extraite. 

13. Methode de gestbn de licences dans un systeme 
55 de traitement de donnees num6riques, methode qui 

comprend I'etape qui consiste k repondre, k I'aide 
d'un gestionnaire de licences (10) ^ une demande 
d'usage pour utitiser un programme togiciel sous 
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licence (14), et Element I'dtape qui consiste h 
g6n6rer une valeur de date de systdme et d compa- 
rer ladite valeur de date de systdme avec une date 
d'interruption pour determiner si I'usage dudit pro- 
gramme logiciel sous licence (1 4) est autonsd, ladite s 
m6thode 6tant caract6ris6e en ce qu'elte comprend 
^galement les 6tapes qui consistent d : 

A. stocker dans une base de donn6es de 
licence (11 ) comprenant plusieurs entries (20) 
respectivement associ§es k un programme 
logiciel sous licence (14): 

une valeur d'unit6s de licence dans une 
zone d'unit6s de licence (25) de chaque 
entr6e (20), tdentifiant un nombre d'unit6s 
de licence associ^es au programme logi- 
ciel sous licence (14), 
une identification d'une table d'attribution 
d'usage (43) dans une zone d'identification 20 
de table d'attribution d'usage (26. 27) de 
chaque entree (20), et 
une date d'interruption dans une zone de 
date d'interruption (31, 32) de chaque 
entree (20); 2S 

B. stocker dans une table d'unit^s de licence 
(12) plusieurs tables d'attribution d'usage (43). 
chaque table d'attributbn d'usage (43) compor- 
tant plusieurs entries d'attribution cf usage (41 ) 30 
dont chacune est associde k un crit^re de selec- 
tion de valeur d'attribution d'usage de licence et 
contient une valeur d'attributbn d'usage qui 
identifie un nombre d'unit6s de licence; 

C. conc^der un usage k I'aide d'un gestionnaire 35 
de licences (10). en 

i. recevant un message de demande 
d'usage au niveau dudit gestionnaire de 
licences (1 0) k partir d'un programme togi- 40 
ciel sous licence (14), ledit message de 
demande d'usage identifiant ledit pro- 
gramme bgbiel sous licence (1 4) et descri- 
tdres de concession d'usage; 

ii. rdpondant k la rdceptbn d'un message 45 
de demande d'usage en extrayant de ladite 
base de donnSes de licence (1 1 ) I'entrde de 
table de licence (20) assocl6e audit pro- 
gramme logiciel sous licence (14); 

iii. extrayant de ladite table d'unites de ^ 
licence (12) une entr6e d'attribution 
d'usage (41) identifi6e par ladite entr^ de 
table de licence (20) extraite et le critdre de 
selection de valeur d'attribution d'usage de 
licence identifid par le message de ^ 
demande d'usage regu; et 

iv. traitant ladite demande d'usage en : 



(a) comparant le contenu de ladite 
zone d'unites de licence (25) et de 
ladite zone d'unites d'attribution 
d'usage (41 ) et de rTK)yens de compa- 
raison de date afin de comparer la 
valeur de date de systdme avec le con- 
tenu de ladite zone de date d'interrup- 
tion (31 , 32) pour determiner si Tusage 
dudit programme bgiciel sous licence 
(14)estautorisd; 

(b) g^nSrant un message en r^ponse 
k la determination par lesdits moyens 
de determinatk)n d'usage; et 

(c) ajustant le contenu de ladite zone 
d'unites de licence (25) en reponse k 
une determinatbn positive par lesdits 
moyens de detemnination d'usage; et 

D. resilier I'usage k I'aide dudit gestbnnaire 
de licences (10)en : 

i. recevant un message de demande 
d'usage au niveau dudit gestk>nnaire 
de licences (10) k partir d'un pro- 
gramme logiciel sous licence (1 4), ledit 
message de demande d'usage identi- 
fiant ledit programme bgiciel sous 
licence (14) et des critdres de conces- 
sbn d'usage; 

ii. repondant k la rdceptbn d'un mes- 
sage de demande d'usage en 
extrayant de ladite base de donnees de 
licence (1 1 ) I'entree de table de licence 
(20) associee audit programme logiciel 
sous licence (14); 

iii. extrayant de ladite table d'unites de 
Ibence (12) une entree d'attributbn 
d'usage (41 ) identifi6e par ladite entree 
de table de licence (20) extraite et le 
critere de s6lectk)n de valeur d'attribu- 
tion d'usage de licence ktentifie par le 
message de demande d'usage regu; et 

iv. ajustant le contenu de ladite zone 
d'unites de licence en relatbn avec la 
valeur de ladite entree d'attribution 
d'usage (41 ). 
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FIG. 4A-1 

GRANT LICENSE 



50 USER ISSUES GRANT LICENSE REQUEST TO REQUEST 
USAGE OF LICENSED PROGRAM lH 



SLICENSING POLICY MODULE TRANFERS GRANT LICENSE 
REQUEST TO OPERATING SYSTEM 



520PERATING SYSTEM TRANSFERS GRANT LICENSE REQUEST 
AND SMM VALUE TO LICENSE MANAGEMENT FACILITY 



54 LICENSE MANAGEMENT FACILITY RFRIEVES ENTRY FROM 
LICENSE DATA BASE ASSOCIATED WITH LICENSED PROGRAM 



55 DOES AVAIUBITY TABLE FIELD 26 OF ENTRY 70 RETRIEVEDJO 
FROM LICENSING DATA BASE HAVE A NON-ZERO VALUE 



YES 



56 RETRIEVE CONTENTS OF FIELD OF LICENSE USAGE 
ALLOCATION UNIT VALUE TABLE ^3 IDENTIFIED BY 
AVAILABILITY TABLE FIELD 26 ASSOCIATED WITH 
SYSTEM 16 USED BY USER 



57 DOES VALUE IN LICENSE NUMBER FIELD 25 EXCEED VALUEjfE§. 
IN RETRIEVED FIELD FROM LICENSE USAGE ALLOCATION ' 
UNIT VALUE TABLE 43? 



NO 

60 LICENSE MANAGEMENT FACILITY TRANSMITS REFUSE 
RESPONSE TO OPERATING SYSTEM 13 



Pir 61 OPERATING SYSTEM 13 TRANSMITS REFUSE RESPONSE TO 
4^1^ LICENSING POLICY MODULE 15 
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62 LICENSING POLICY MODULE 15 RECEIVES REFUSE 
RESPONSE FROM OPERATING SYSTEM 13 



/ 

63 IS' LICENSED PROGRAM COVERED BY A GROUP 
LICENSE? I 



YES 



64 ADJUST CONTENTS OF GROUP LICENSE TABLES 
17 TO REFLECT USAGE OF LICENSED PROGRAM 1^1 
UNDER GROUP LICENSE 



65 PERMIT USAGE OF LICENSED PROGRAM 14 



66 IS USAGE OF LICENSED PROGRAM W PERMITTED 
BY LICENSOR'S OTHER LICENSING POLICIES? 

I 

YES 



67 PERMIT USAGE OF LICENSED PROGRAM BY USER 
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TO TERMINATE USAGE OF LICENSED PROGRAM 14 
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/tiDOES activity table field 27 OF ENTRY 20 , 
RETRIEVED FROM LICENSING DATA BASE 11 HAVE 
A NON-ZERO VALUE? 
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75DECREMENT CONTENTS OF LICENSE UNIT NUMBER 
FIELD 25 BY FUNCTION OF CONTENTS OF FIELDS 
OF LICENSE USAGE ALLOCATION UNIT VALUE 
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77 OPERATING SYSTEM 13 TRANSMITS PUS IT I VE 
RESPONSE TO LICENSING POLICY MODULE 15 

80 LICENSING POLICY MODULE 15 PERMITS USAGE 
OF LICENSED PROGRAM W BY USER 

FIG.4B-1 

RELEASE LICENSE 

90 USER ISSUES RELEASE LICENSE REQUEST TO REQUEST 
RELEASE OF LICENSED PROGRAM 14 

91 LICENSING POLICY MODULE 15 DETERMINES WHETHER NO 

USAGE OF LICENSED PROGRAM 14 WAS PURSUANT TO 
LICENSOR'S OTHER LICENSING POLICIES 

I YES 
92 END 



93 LICENSING POLICY MODULE 15 DETERMINES WHETHER HQ. 

USAGE OF LICENSED PROGRAM W WAS PURSUANT 
TO A GROUP LICENSE 

YES 



94 LICENSING POLICY MODULE ADJUSTS CONTENTS OF 
GROUP LICENSE TABLE TO REFLECT RELEASE OF 
LICENSED PROGRAM 



:t R^LE 
95END 



96LICENSING POLICY MODULE 15 TRANSFERS RELEASE 
LICENSE REQUEST TO OPERATING SYSTEM 13 
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101 DOES AVAIUBILITY TABLE FIELD 26 OF ENTRY 20 
RETRIEVED FROM LICENSING DATA BASE 11 HAVE A" 
NON-ZERO VALUE? 



YES 



102 RETRIEVE CONTENTS OF LICENSE USAGE ALLOCATION 
UNIT VALUE TABLE IDENTIFIED BY CONTENTS OF 
AVAIUBILITY TABLE FIELD 



103 



DOES ACTIVITY TABLE FIELD 27 OF ENTRY 2g^RETRIEVEtt. 
FROM LICENSING DATA BASE 11 HAVE A NON-ZERO VALUE? 



NO 



I 



104 RETRIEVE CONTENTS OF LICENSE USAGE ALLOCATION 
UNIT VALUE TABLE IDENTIFIED BY CONTENTS OF 
ACTIVITY TABLE FIELD 



YES 



105 INCREMENT CONTENTS OF LICENSE UNIT NUMBER FIELD 25 
BY FUNCTION OF FIELDS OF LICENSE USAGE ALLOCATION 
UNIT VALUE TABLE RETRIEVED IN STEPS 102 AND 104 
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END 
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